热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

树|二叉树的存储结构和基本操作

二叉树的存储结构二叉树使用链表来定义;结点不存在,指向NULL;structnode{intdata;数据域node*lchild;指向左子树根结点

二叉树的存储结构

二叉树使用链表来定义;结点不存在,指向NULL;

struct node{int data; // 数据域node *lchild; // 指向左子树根结点的指针node *rchild; // 指向右子树根结点的指针
}

在这里插入图片描述

二叉树的基本操作


  1. 二叉树的建立

node *Create(int data[],int n){node *root = NULL;// 新建空根结点rootfor(int i=0; i}

  1. 二叉树结点的查找,修改,插入,与删除

使用递归来完成查找修改工作;
递归式:指对当前结点的左子树和右子树分别递归
递归边界:当前结点为空时到达子胡同

void search(node *root, int x, int newdata){if(root == NULL){return;}if(root->data == x){root->data = newdata;} search(root->lchild, x, newdata);search(root->rchild, x, newdata);
}

插入

void insert(node *&root, int x){if(root == NULL){root == newNode(x);return;}if(由二叉树的性质,x应该插在左子树){insert(root->lchild, x);}else{insert(root->rchild, x);}
}

如何判断是否要加引用呢?

一般来说,如果函数中需要新建结点,即对二叉树的结构做出修改,就需要加引用;如果只是修改当前已有结点的内容,或仅仅是遍历树,就不需要加引用。至于判断不出来的情况,不妨直接试一下加引用和不加引用的区别再来选择。

  • 在新建结点之后,务必令新结点的左右指针域为NULL,表示这个新结点暂时没有左右子树。

代码

#include
#include
#include
using namespace std;struct node
{int data; // 数据域node *lchild; // 指向左子树根结点的指针node *rchild; // 指向右子树根结点的指针
};
node *newNode(int v)
{node *Node = new node;Node->data = v;Node->lchild = Node->rchild = NULL;return Node;
}
void insert_node(node *&root, int x)
{if (root &#61;&#61; NULL){root &#61; newNode(x);return;}if (x <&#61; root->data){insert_node(root->lchild, x);}else{insert_node(root->rchild, x);}
}node *Create(int data[], int n)
{node *root &#61; NULL; // 新建空根结点rootfor (int i &#61; 0; i }void printNodes(node *root)
{if (root &#61;&#61; NULL){return;}printf("%d ", root->data);printNodes(root->lchild);printNodes(root->rchild);return;
}
int main()
{int data[] &#61; {10, 9, 8, 7, 6};node *root &#61; Create(data, 5);printNodes(root);return 0;
}


推荐阅读
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • 本实验主要探讨了二叉排序树(BST)的基本操作,包括创建、查找和删除节点。通过具体实例和代码实现,详细介绍了如何使用递归和非递归方法进行关键字查找,并展示了删除特定节点后的树结构变化。 ... [详细]
  • 本文详细介绍了C语言中链表的两种动态创建方法——头插法和尾插法,包括具体的实现代码和运行示例。通过这些内容,读者可以更好地理解和掌握链表的基本操作。 ... [详细]
  • 本文详细探讨了VxWorks操作系统中双向链表和环形缓冲区的实现原理及使用方法,通过具体示例代码加深理解。 ... [详细]
  • 本题涉及一棵由N个节点组成的树(共有N-1条边),初始时所有节点均为白色。题目要求处理两种操作:一是改变某个节点的颜色(从白变黑或从黑变白);二是查询从根节点到指定节点路径上的第一个黑色节点,若无则输出-1。 ... [详细]
  • Codeforces Round #566 (Div. 2) A~F个人题解
    Dashboard-CodeforcesRound#566(Div.2)-CodeforcesA.FillingShapes题意:给你一个的表格,你 ... [详细]
  • 本文详细探讨了KMP算法中next数组的构建及其应用,重点分析了未改良和改良后的next数组在字符串匹配中的作用。通过具体实例和代码实现,帮助读者更好地理解KMP算法的核心原理。 ... [详细]
  • 本文介绍如何使用Objective-C结合dispatch库进行并发编程,以提高素数计数任务的效率。通过对比纯C代码与引入并发机制后的代码,展示dispatch库的强大功能。 ... [详细]
  • C++实现经典排序算法
    本文详细介绍了七种经典的排序算法及其性能分析。每种算法的平均、最坏和最好情况的时间复杂度、辅助空间需求以及稳定性都被列出,帮助读者全面了解这些排序方法的特点。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 本题通过将每个矩形视为一个节点,根据其相对位置构建拓扑图,并利用深度优先搜索(DFS)或状态压缩动态规划(DP)求解最小涂色次数。本文详细解析了该问题的建模思路与算法实现。 ... [详细]
  • 在多线程编程环境中,线程之间共享全局变量可能导致数据竞争和不一致性。为了解决这一问题,Linux提供了线程局部存储(TLS),使每个线程可以拥有独立的变量副本,确保线程间的数据隔离与安全。 ... [详细]
  • 本次考试于2016年10月25日上午7:50至11:15举行,主要涉及数学专题,特别是斐波那契数列的性质及其在编程中的应用。本文将详细解析考试中的题目,并提供解题思路和代码实现。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
author-avatar
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有